<template>
</template>

<script>
import { mapState } from 'vuex'

export default {
  name: "Websocket",
  data() {
    return {};
  },
  computed: {
    ...mapState({
      token: state => state.user.token,
      websocket: state => state.user.websocket
    })
  },
  watch: {
    websocket({ password, path, port, interval}) {
      // 建立 websocket 连接
      this.socket.initialize({
        url: 'ws://' + location.hostname + ':' + port + path,
        password: password,
        tokenSN: this.token,
        heartRate: interval
      });

      this.socket.onmessage = (message) => {
        message = JSON.parse(message)
        const method = message.method;

        if (method !== 'event')
        {
          return;
        }

        const params = message.params;
        const subEvent = params.subEvent;
        const content = params.content;
        switch (subEvent)
        {
          case 'reactive':
            this.$store.dispatch('HandleReactiveResponse', content)
            break;
          // 支付
          case 'payment_webSocket_send':
            this.$store.commit('PAYMENT', content)
            break;
          default:
        }
      }
    }
  },
  created() {
  },
  methods: {
  }
};
</script>


